-
-
Notifications
You must be signed in to change notification settings - Fork 828
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add live proxy feature #512
Conversation
@ndajr I'm trying to test this out in a dockerized chi app. Could I please have some clarification on how this should work? I've updated my dockerfile to point to your branch and install air as per below: FROM golang:1.21
WORKDIR /jacc
COPY . /jacc/
RUN apt-get update && apt-get install wkhtmltopdf -y
RUN go mod download
RUN go mod verify
RUN go install github.com/a-h/templ/cmd/templ@latest
RUN git clone https://github.com/ndajr/air ~/.air && cd ~/.air && go install . && cd -
CMD air -c .air.toml and I've updated my [proxy]
enabled = true
proxy_port = 8080
app_port = 3000 I've opened up both ports in my docker-compose. My chi app listens on port 3000. Tested live reloading on port 3000 - updated a file, watched air recompile and restart the server but no refresh on the browser side. The changes only appear after a manual refresh. Port 8080 is unresponsive. Any idea what I could be doing wrong? |
Hey @scottmckendry, I have changed the proxy config to accept urls not just ports, so that it works also with docker compose. Please try this: https://github.com/cosmtrek/air/pull/512/files#diff-b335630551682c19a781afebcf4d07bf978fb1f8ac04c6bf87428ed5106870f5R214 |
Thanks @ndajr but I'm not convinced that was the issue. I'm running the container locally so using the default Either way, I've updated the .air.toml config as per your documentation. But still no difference, unfortunately. Perhaps I need some clarity on expected behaviour. If my app is listening on port 3000 and the proxy is configured to port 8080, which URL should I be using to access the app? What should I be expecting to see after air reloads? |
@scottmckendry you should access the proxy url, in your case it's 8080. Proxy will try to call your chi app on port 3000 and you should see the exact same page with an added script before the body html tag, which does the live reloading without you having to change the code of your app. You can try to access it outside of docker and see if it works, you can post here the full docker-compose and Dockerfiles and I can try to reproduce |
Hi @ndajr 👋 I've made some progress on my end. Turns out I was cloning the wrong branch in my dockerfile. Adding Sadly, I'm still getting no response on the proxy URL. I suspect this is due to my docker config. I've pushed my current setup to the air-proxy-reload branch in the repo if you want to take a look. Appreciate your help 🙂 |
431ae91
to
6b0217e
Compare
Hi @scottmckendry, I think now I've got more clarity on what the issue was. Althougth listening on [proxy]
enabled = true
proxy_port = 8080
app_port = 3000 I had to deal with a lot more edge cases parsing the full url and it wasn't worth it. My branch is updated, let me know how it goes. |
Brilliant! That's working perfectly now. Great stuff. |
When using htmx to perform an update with partials the proxy fails due to the lack of body tag in the response. Clicking this button: <button hx-get="/user/more" hx-target="#data">
Load fresh data
</button>
<div id="data"></div> Calls an endpoint which returns this partial: package user
templ More() {
<p>Injected partial</p>
} Which causes this error:
|
Hi @zolrath, thanks for testing the feature with htmx! Initially I was locating the end of the body tag just to know where to insert the live reload script. As we don't want each partial template to be listening to live reload events, just the main page, I pushed a change to proxy the original fragment in case the body tag is missing (instead of erroring), so only the main page will do live reloading. |
Hm, my form POST doesn't seem to work with the latest version of the proxy. The most obvious difference between the two results I'm about to post are the When I submit a form with an hx-post to an endpoint with {
"time": "2024-01-28T23:45:29.537573732-08:00",
"id": "",
"remote_ip": "::1",
"host": "localhost:3000",
"method": "POST",
"uri": "/win",
"user_agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36 Edg/121.0.0.0",
"status": 200,
"error": "",
"latency": 46378798,
"latency_human": "46.378798ms",
"bytes_in": 15,
"bytes_out": 0
} If I am running it through the air proxy: {
"time": "2024-01-28T23:46:26.249693344-08:00",
"id": "",
"remote_ip": "[::1]:45426",
"host": "localhost:3000",
"method": "POST",
"uri": "/win",
"user_agent": "Go-http-client/1.1",
"status": 200,
"error": "",
"latency": 9799,
"latency_human": "9.799µs",
"bytes_in": 0,
"bytes_out": 0
} |
Hi @zolrath, sorry for the delay, this should be fixed by now. Let me know how it goes |
@zolrath, good finding, I pushed yet another fix, this time actually simplifying the reload script to simply refresh the page which should be more reliable. On the other hand, you will need some |
I tried out this branch and it works, but since I don't want to compromise on my port I put the refresh script in manually. |
Is there any update on this? |
I'm happy to move this feature forward, do adjustments or fixes (like CORS or httputil mentioned above), but first I'd like to hear from @cosmtrek or one of the maintainers if they want this |
This is the killer feature. Imagine having hot reload without live reload and press f5 for every tailwind tweak... |
i use this branch, and it's work perfectly to refresh go-htmx-templ project with tailwindcss rebuild. |
This is amazing work @ndajr |
well done! I will review this PR within next week. |
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## master #512 +/- ##
==========================================
- Coverage 69.22% 67.53% -1.70%
==========================================
Files 9 12 +3
Lines 1082 1078 -4
==========================================
- Hits 749 728 -21
- Misses 253 262 +9
- Partials 80 88 +8 ☔ View full report in Codecov by Sentry. |
LGTM. WEEEEELL done!!! |
I learnt a lot from your PR. tks |
Great PR |
Thanks for the push, but how can I make this work in container? |
You need to open both your app and proxy ports on the container. Your container should also have air as an entry point. If you want an example you can take a look at the dev.dockerfile and docker-compose configs in one of my projects here: |
I am totally new in Golang. I didn't explain myself correctly, I want to the website refresh when updating a tmpl/html, or statics file, is this possible and how? this is my air.toml:
I am executing air from container, but go project is in host and not container. How I execute the container: add this in .bashrc or .$SHELLrc Then in the project root: |
Description
This PR implements what is discussed in this issue: #141. I started a new webapp using Go templates and would like to have a live reloading functionality (not just hot reloading when files change). The two possible implementations are with websockets or with server-sent events. I chose the latter because it adds the least amount of complexity and no external dependency is required. I'd like some feedback on the config names (port and app_port, or frontend_port and backend_port?) and whether proxy should be enabled by default or not.
How to use
It is quite simple to use, add the proxy config, in my case I added my views containing the go templates on
include_dir
, and access the proxy port, e.g.http://localhost:8090
.How it works
There are two handlers on the proxy, the root handler
/
which is a catch-all and should proxy all requests and the/internal/reload
endpoint which implements server-sent events. The root handler proxies all the requests and injects a script that listens to/internal/reload
and reloads the browser every time air watches a file change.